// src/main.ts（TypeScript 版本）
import { createApp } from 'vue'
import { createPinia } from 'pinia'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import * as ElementPlusIconsVue from '@element-plus/icons-vue'
// 导入路由实例（TypeScript 会自动校验路由实例类型）
import router from './router'
// 导入根组件（Vue 3 对单文件组件的类型支持）
import App from './App.vue'

// 创建 Vue 实例（TypeScript 自动推断实例类型）
const app = createApp(App)

// 注册 Element Plus 图标（遍历对象时无需额外类型声明）
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  app.component(key, component)
}

// 挂载依赖（顺序不影响，TypeScript 会校验依赖是否符合挂载要求）
app.use(createPinia())
app.use(ElementPlus)
app.use(router)

// 挂载根组件到 DOM
app.mount('#app')
